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(g) A telephonic switching system (11) with a 
s^Mtcn (10) controlled by a central processing 
unit {^2) to interconnect interior communi- 
cation units (14) and exterior telephonic units 
06) in accordance with data in a shared data 
memor/ (18) with data that is alterable in res- 
ponse to signals generated by the communi- 
cation units. A data memory access system (23) 
periodically shifts access to the data memory 
(13) from one special process to another suc- 
cessive special process in a process memory 
(20). The data memory access system (23) pre- 
vents the normal periodic shifting of access to 
the data memory (18) during a period when the 
special process with access is enabled to ac- 
cess and alter shared data. 
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i|7) A telephonic switching system (11) with a 
switch (10) controlled by a central processing 
unit (12) to interconnect interior communi- 
cation units (14) and exterior telephonic units 
(18) in accordance with data in a shared data 
memory (18) with data that is alterable in res- 
ponse to signals generated by the communi- 
caton units. A data menrrary access system (23) 
penodk:ally shifts access to the data memory 
(18) from one special process to another suc- 
cessive s pedal process in a process memory 
(20). The data merrwry access system (23) pre- 
vents the normal penodic shifting of access to 
the data memory (18) during a period when the 
special process with access is enabled to ac- 
cess and alter shared data. 




CL 
UJ 



EP 0 569 195 A2 2 



BACKGROUND OF THE INVENTION 

F e'd of the Invention 

This invention relates generally to telephone 
svvttching systems and methods and more particular- 
'y :o teieoncntc switcning systems and methods in 
whicn access of aifferent special processes to a 
shared aata memory is controlled to prevent access 
to shared data by one special process when the data 
is in the process of being altered by another special 
process. 

Description of the related art including information 
disclosed under 37 CFR §1.97 - 1.99 

In modern computer controlled communication 
switching systems there are a plurality of different 
special functions which must be performed. While 
these special functions can each be performed by 
separate devices or by separate processes of a single 
central processing unit. In either event, often a plur- 
ality of special processes require access to a single 
data memory which is shared on a time slicing basis 
between all the special processes. In -performing 
their special functions, some of the special processes 
alter the data which is shared with other special proc- 
esses. In known telephonic systems, the access to 
the shared data memory is automatically, periodically 
shifted successively from one special process to an- 
other without regard to whether the shared data is be- 
ing altered and is incomplete at the time for the peri- 
odic shift in access. This disadvantageously can re- 
sult in erroneous reading or storage of data and con- 
sequent malfunctions of the telephonic system. 

This periodic shifting of access is commonly 
known as '*time slicing*. In a central processor based 
system, the concept of time slicing relates to the al- 
location of central processor unit time across a nurrv 
ber of processes requesting CPU time. When a time 
slice occurs, access to the data stored in a data mem- 
ory through the CPU is shifted from the special proc- 
ess currently accessing the data to another special 
process which has requested access to the data. The 
operating system of the central processing unit allo- 
cates read lines to the central processing unit from 
the number of processes requesting access to data 
through the central processing unit. As noted, the 
processing of an event can require the updating of 
multiple pieces of data. If a time slice occurs in the 
middle of this updating interval, it is possible that an- 
other process could read this data erroneously after 
the occurrence of a time slice and cause a software 
failure. 

The known soluti n to this problem in a CPU con- 
trolled telephonic switch is to administer data access 
flags to determin when a piece of data can b ac- 
cessed. 



Disadvantageously. with this known aooroacr. :o irr.e 
slicing :n a multiuser or multiorocess system. -Lrrer- 
ous extra data oits m the data itself are reauirec as 
flags. When the operating system moicates that time 

5 allocated to process time has lapsed ana access to 
the CPU has shffteo uoon a time siice, ihe?» extra 
flag bits are neeaea to direct the SDec:ai orocess to 
return to its last completed step when it is aiiowea :o 
resume processing. These extra data oits. or sema- 

w phores. associated with the accessed data are aiso 
used to inform other special processes by signalling 
a flag to indicate that the data involved or associated 
with these data bits are possibly m the act of bemg 
changed and that the other processes snould not use 

IS the data as it is not necessarily accurate at that mo- 
ment 

This known flag technique disadvantageously re- 
quires the expenditure of a substantial amount of real- 
time overhead in administering semaphores for every 

20 access of data to prevent multiple accesses to the 
data as a result of time slicing. This leads to undesir- 
able real time utilization. The known multiprocesses 
systems require the special processes to account for 
the possibility of being time sliced at any point in their 

25 execution through the use of software protocols be- 
tween the processes which access shared data. This 
makes the interaction between application processes 
which share data more complex. 

Referring to Fig. 1. a block diagram of the known 

30 method for multiple processes to access data from 
the same data area. In step 5. when a special process 
attempts to access data, the special process wilt ask 
if the data area of the data memory has been locked, 
because data is being accessed by another process. 

35 In step 6, if the data memory area is not locked by an- 
other process, the special process will begin execu- 
tion by first setting a data access flag or locking the 
data area, itself. In step 7, the special process will 
then access the data from the data area of the data 

40 memory. Finally, after the process has completed all 
the accessing of its requested data, the flag associ- 
ated with the data will be removed and the data area 
will be unlocked in step 8. If the data is being ac- 
cessed by another special process, in step 9 a delay 

45 will result because the special process will read a flag 
associated with this data indicating that the data is 
locked by another process and therefore no further 
access to this data may result until the other process 
completes its access of the data and unlocks the data 

50 area. Therefore, if a time slice occurs while a special 
process is still accessing data thereby locking the 
data area, the next process which is allocated a read 
line through the CPU as a result of the time slice wilt 
not be able to access th data area because the orig- 

55 inaily accessing process which was time sliced has 
kept the data area locked. 

As a result all other succ ssrve special process- 
es which desire to access the locked data have their 
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execurion delayed because they will not be able to ac- 
cess :ne data required to run the orocess until the 
syscem eventually gets back to the original accessing 
crccsss and tne soecral process completes its access 5 
'ron the aa:a area and finally unlocks the data area 
by removing its flag. Thus, m addition to the necessity 
of needing a mgh real-time overhead, the known 
method of Fig. 1 leads to long response times for real 
time events still aue to the fact that when a process w 
is time sliced upon accessing data, access by no 
other process can occur until the process with access 
returns to execution and completes the access. Since 
there is no integration of time slicing with the preven- 
tion of accessing shared data, the time slicing of proc- is 
esses actually adds to delays and long response 
times. 

SUMMARY OF THE INVENTION 

20 

It is therefore the principal object of the present 
invention to provide a computer controlled telephonic 
switching system with a system and method in which 
access to a shared memory is controlled to prevent 
time slicing at inappropriate times and thereby avoid 25 
the problems of delay, inefficiency and the introduc- 
tion of error in known systems. 

This objective is achieved in part through provid- 
ing a telephonic switching system having a switch 
controlled by a central processing unit to interconnect so 
interior communication units with exterior communi- 
cation units in accordance with communication data 
in a communication data memory which is alterable m 
response to signals initiated by said communication 
units in accordance with an operating system having 35 
a plurality of special processes which share the data 
with a shared data memory access system, with 
means for periodicalty shifting access to shared data 
in the data memory successively between said plur- 
ality of special processes and means for controlling 40 
the access shifting means to prevent said access 
shifting means from shifting access to the data menrv 
ory from one of said plurality of special processes to 
another one of said plurality of special processes dur- 
ing a period when the one of said plurality of special 45 
processes with access to the data memory is enabled 
to access shared data. 

The objective is also achieved by providing such 
a telephonk: switching system with a method of con- 
trolling access of the special processes to the shared so 
data comprising the steps of normally periodically 
shifting access to the alterable data nnemory between 
said plurality of sp ctal processes except when pre- 
vented, d termining when on of sakJ plurality of spe- 
cial processes has access t shared data in said al- 55 
terable data memory and preventing periodic shifting 
of access away from the on of said plurality of spe- 
cial processes with access during a p riod when it is 
determined that shared data is being accessed by the 
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one soecial process with access. 

BRIEF DESCRIPTION OF THE DRAWING 

The foregoing objects and aavantageous fea- 
tures of the invention will be explained in greater re- 
tail and others will be made apparent from tne re- 
tailed description of the preferred embcaiment of c.^e 
present invention which is given with reference :o rne 
several figures of the drawing, in which: 

Fig. 1 is a flow chart illustrating the PRIOR ART 

method of time slicing access between a olciratity 

of special processes: 

Fig. 2 is a functional block diagram of a oreferrea 
embodiment of the telephonic switching syscem 
with the shared data memory access system of 
the present invention; 

Figs. 3A, 38 and 3C are operating system flow 
charts of the preferred embodiment of the meth- 
od for controlling access to a shared data mem- 
ory of the telephonic switching system of Fig. 2; 
Fig. 4 is a flow chart of t he preferred embodiment 
illustrating the sequence of events for a soecial 
process controlling access to a data memory of 
the telephonic switching system of Fig, 2: and 
Fig. 5 is a table illustrating an example of how the 
preferred embodiment of the telephonic switch- 
ing system of Figs. 2, 3A. 38. 3C and 4 functions 
in different situations. 

DESCRIPTION OF THE PREFERRED 
EMBODIMENT 

Referring now to Fig. 2. a block diagram of the 
preferred embodiment of the telephonic switching 
system 11 of the present invention is seen to include 
a multiport switch 10 which is controlled by a central 
processing unit 12 to interconnect a plurality of inter- 
ior communication units 14 with a plurality of exterior 
communication units 16, An exterior communication 
unit 1 6 provides a signal to the switch 1 0 which directs 
this signal to the central processing unit 12. The cen- 
tral processing unit or CPU. 12 accesses data in a 
data memory 18. The central processing unit 12 has 
associated with it a processes memory area 20 which 
contains control for a plurality of special processes 
and an operating system 21 which manages the 
amount of time which each special process has to ac- 
cess data from the data memory 1 8. While the details 
of the switch 10. central processing unit or the other 
elements of the telephonic switching system, a pre- 
ferred form of the syst m is described in greater de- 
tail in patent applications U. S. Serial No. 07/770.197 
of Jones et at. filed October 2. 1991: U.S. Serial No. 
07/416.077 of Jones et al. filed September 29. 1939 
and U.S. Serial No. 07/408.165 of Lenihan et al. filed 
September 15, 1989. 

These special processes in the processes mem- 
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cry 20 are triggered by a signal either coming from the 
exterior telephonic or other communication units 1 6 or 
an interior telephonic or other communication unit 1 4. 
Uoon being activated by a signal, the special process- 
es of process memory 20 require access to the data 
■n tne data memory 18. Some special processes re- 
quire that the data be altered in order for the special 
process to carry out its particular function. The data 
memory access system 23 associated with the oper- 
ating system 21 of the CPU 1 2 prevents a successive 
special process from accessing data which has been 
manipulated or altered by a special process with ac* 
cess when the operating system attempts to time slice 
the special process with access in order to allow ac- 
cess of this data to a successive waiting special proc- 
ess that request access to the data. 

The data memory access system 23 includes 
means for periodically shifting access to the data in 
the data memory 18 from a plurality of special proc- 
ess requesting access to this data. As seen in Fig. 3C. 
this access shifting means includes means for provid- 
ing a periodic interrupt signal 40 which is generated 
by the operating system 21. Commonly an interrupt 
signal 40 is generated every ten milliseconds, as in 
Fig. 3C. by the operating system 21 to ret^uest a time 
slice. However, the operating system is enabled to be 
set to generate this interrupt signal 40 at any chosen 
periodic interval. Upon the triggering of each periodic 
interrupt signal 40. a time slice occurs and the oper- 
ating system allocates CPU time to the next succes- 
sive special process waiting to access data through 
the CPU 12 to the data memory 18. 

The shared data memory access system 23 also 
has means for controlling the access shifting means: 
thus, time slicing is at certain times allowed and at 
other times is prevented by the controlling means. 
The perioaic interrupt 40 will continue to be signalled 
at each interval when the access surface 23 is opera- 
tional. However, the access system 23 determines 
when a time slice occurs in response to a special proc- 
ess accessing data which is shared between more 
than one special process. 

The data memory access system 23 modifies the 
code of the operating system 21 to indude a utility 
routine which is called by the special process in mem- 
ory 20 in response to the special process accessing 
data that is shared. When a special process accesses 
data that is enabled to be shared by other special 
processes, it has reached a criticat section of the data 
memory 18. As seen in Fig. 4. in step 72. in response 
a special process entering a criticat section, a subrou- 
tine is called. As seen in Fig. 3Aand 4. this subroutine 
of the shared data menwry access system 23 in the 
operating system 21 is called e_set_no_time_siice 30. 
Since the special process has entered into a critical sec- 
tion of th data, in step 72. Fig. 4. th pmcess wil re- 
quest the routine t set the no_time_slice flag. In step 
3Z a determination is mad whether a no_time_slice 



flag is being requested to be set in a first cata oit or 
the request from the special process. In step 3^. 
when this flag is set, successive soeciai orocesses 
5 will not be permitted to be shifted m order to access 
shared data from the data memory 13 uoon tiie gen- 
eration of the interrupt signal 40 by the operating sys- 
tem. Thus, when the flag is set in steo 34. a time slice 
will not automatically occur merely because a ten mii- 

w lisecond interrupt 40 has occurred. The flag indicates 
to the other special processes that a special process 
is accessing the shared data from the data memory 
18. Fig. 1. in a critical section of the data memory 13 
and thus the data has the possibility of being maniou- 

15 lated or changed. 

In order to avoid successive processes from ac- 
cessing data which is incomplete or inaccurate be- 
cause the data is being manipulated by the special 
process with access, the nojime^slice flag is set in 

20 step 34 to prevent an automatic time slice from occur- 
ring when the periodic interrupt signal 40 is generat- 
ed. Therefore, in step 74. Fig. 4. the special process 
with access to the shared data in memory 18 contin- 
ues to execute its programmed tasks and continues 

25 to access the data from the data memory 18. As a re- 
sult of this, the response times for completing events 
within a process are gready reduced. As seen in Fig. 
3C. if in step 32 it is determined that the no_time_sli- 
ce flag has not been set. then the special process 

30 with access is not accessing shared data and thus a 
time slice will automatically occur in step 44. The ac- 
cess to the data memory 1 8 will shift without long de- 
lays to the next successive special process in re- 
sponse to the ten millisecond interrupt signal being 

35 generated in step 40 by the operating system and 
then return in step 52 to execute its assigned task. 

Each time the periodic interrupt signal 40 the op- 
erating system will ask if a nojime_stice flag has 
been set in step 42. If the nojime^slice flag is set in 

40 step 42. a counted tick value, also called the 
procJick_cnt is generated in another, or second, 
data bit of the special process will access data in step 
46. This procjick_cnt value indicates the number of 
times that the operating system has requested a time 

45 slice to occur but no time slice has taken place due to 
the no_time_slice flag being set in the first data ele- 
ment in step 42. The proc_tick_cnt is used for two pur- 
poses. First the proc_tick_cnt is used by the operat- 
ing system 21 to determine how long a special proc- 

50 ess has prevented from time slicing. If a special proc- 
ess has prevented time slicing for more than a prese- 
lected number of counted ticks, such as twenty, in 
step 48 the operating system will trigger an override 
actk)n and abort th running of the special process 

S3 in step 50. This uses the procjick_cnt as a check to 
see if there is an error in th process becaus the 
process has been running for too great a period of 
tim without allowing for a time slice. The 
proc_ticfc_cnt is similarly used t signal that a warn- 
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'ng message is to oe pnnted if the proc_tick_cnt has 
reachea a oreselected value, such as three ticks. 

As seen in Fig. 38. the Dfoc_lick_cnt is also used 
by a utility routine 60 m tne operating system 21. 
caileo ESCH£D_CHECK, to determine if the process 
snould voluntarily request a time slice. This is the sec- 
ond purpose for which the procjick_cnt is used. In 
step 75. Fig. ^, when the special process is accessing 
the data from the data memory, the process calls the 
ESCHEO^CHECK subroutine 60 in the operating 
system 21 upon the special process reaching a safe 
point in the data. 

A safe point occurs when the special process de* 
termines through its code that an event within the 
process has been completed and that if a time slice 
were to occur, there would be no possibility of a sub- 
sequent special process accessing incomplete data. 
As seen in Fig. 38, when the ESCHED_CHECK rou- 
tine 60 is called, it reads the proc_ticK_cnt to determine 
if the value is equal to zero in step 62. If the proc_tick_cnt 
is equal to zero, then the operating system has not re- 
quested a time slice and the ESCHED_CHECK routine 
will return in step 68. In such event, no time slice will 
occur and the special process will continue to access 
shared data in step 76. Fig. 4. As seen.in Fig. 38, if 
the proc Jick^cnt. is at a value not equal to zero, then 
the operating system will reset the procjick_cnt val- 
ue to zero in step 64 and a voluntary time slice auto- 
matically results in step in step 66. This results in pro- 
viding a shifting of access to the data memory 18 from 
the special process with access to a successive spe- 
cial process waiting for access. This voluntary time 
slice 66 is allowed under these conditions because 
the data ceinc atcessec Dy the process is at a safe 
point. In or-ef .vords. the process has finished a se- 
quence cf =.:ces5es and thereby completed an event 
of the 3rc> cis wnich leaves the accessed data in a 
fully uccaiec state. 

When :ne operating system also requests a time 
slice duf'no the interim period which the no_time_sll- 
ce than nas been set the special process with access 
is aware t.^.at >t is safe for a time slice to occur, so the 
process witn voluntary "gives itself up* in step 66 and 
allows the ooerating system to shift access to the 
data memory to another special process before 
ESCH£D_CHECK 60 returns in step 68. Thus, the 
special process, or user controls the access to the 
data in the data merrtory. since the special process 
with access is what calls the ESCHED_CHECK utility 
routine 60 to determine if a voluntary time slice in step 
66 is proper. 

As seen in Fig. 4. in step 78, when a special proc- 
ess has completed accessing shared data, and thus 
exits a chtical secti n of data, the process calls the 
e_s t^nojim _slic routine 30. Fig, 3A, to r set the 
nojim _slice flag. 

Referring again to F»g. 3A, the e_set_no_time_slice 
utility routine 30 associated with the operating system 



2 1 resets the nojime_siice flag in the first data eierrer: 
bit of the soeciai process when the cnticai section of ine 
process has ended in step 36 if it is aetermmeo m 5teo 

5 32 that there is no time slice Mag oemg reauested to ze 
set in step 32. After resetting the nojime_slice flag m 
step 36. the e_set_no_time_slice routine 30 ca''s i.'^e 
ESCHED_CHECK utility routine 60 of Fig. 38 m steo 37 
to read the procjick_cnt m step 62 in the other or sec- 

ro ond data element bit of the special process toaetermme 
if a user controlled voluntary time slice is to occur 5;nce 
the running process or process with access, knows ;t -s 
at a safe point at the end of the critical section. 5 an 
appropriate time to call ESCHED_CHECK 60 :n steo 

15 37. Fig. 3A. and a time slice in step 66 automatical'/ 
results if the procjick_cnt value read in step 62 5 :e- 
termined to have a value other than zero. 

After the no_time_slice flag has been reset in 
step 36, the state of the value of the flag wilt be re- 

20 turned in step 38 to its pnor value which the flag had 
before the no_time_slice flag was set. This is done 
because many special processes call other special 
processes as subroutines to execute their tasks. If 
the special process with access has entered a critical 

25 section, thereby having a no_time_slice flag value at 
an "on" state, when it calls another special process as 
a subroutine, the other called special process will 
have to execute its own tasks. The called subroutine 
process has its own e_set_nojime_slice routine 

JO which turns on when it reaches its own critical section 
upon accessing potentially shared data and will then 
have a flag value, or state, of "off at the end of the 
critical section. However when the called subroutine 
special process turns off, its e_set_no_time_slice 

35 routine 30 will also turn off the e_set_no_Eime_slice 
routine 30 for the original executing special process 
which called the subroutine process. Therefore, when 
a no_time_slice flag is reset in step 36 at the end of the 
critical section, the value of the no_time_slice flag will 

40 be returned in step 38 to its same prior state as existed 
before the flag was set In this case the flag value will be 
returned to an "on" state, since the nojime_slk:e flag 
was originally in an "on" state, since it had entered a crit- 
ical section when the subroutine was first called. This is 

45 done to prevent the e_set_no_time_slice routine 30 
from being blindly turned off by a called subroutine. 

Referring to Fig. 5. the user controlled time slic- 
ing table 70 illustrates an example of a sequence of 
events that shows how the process, also called the 

50 user is utilized to control when time slices occur with- 
in its process. At the zero millisecond time the special 
process is activated by a signal from the exterior com- 
munication units 16 or interior communication units 
14. The special process begins to execute its as- 

55 signed tasks and will access data from the data 
memory 1 8 through the central processing unit 1 2. 
At the zer millisecond time the first data ele- 
ment bit no_time_slice flag is off and in a reset state, 
and the other or second data element bit, the 
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orocjick_cnt. is assigned a zero value. 

At the ten millisecono time of Fig. 5. the operating 
system will automatically time slice in step 44 the spe- 
cial orocess with access in response to the triggering 5 
of the ten millisecond interrupt signal 40. since the 
no j!me_stice Hag nas not been set. Therefore at this 
rtme. the operating system will shift access to the 
memory 18 from the special process which was acti- 
vated Eo the next successive special process which 10 
was waiting to obtain access to the data memory 18. 
No modification is made to the proc_tick_cnt value or 
the no_time_siice flag value upon the operating system 
generating the ten millisecond interrupt signal 40. 

At the twenty millisecond time of Fig. 5. another »5 
periodic ten millisecond interrupt in step 40 occurs, 
and in step 44 the process with access is time sliced. 
Then, the operating system returns execution to the 
original special process which was activated at the 
zero millisecond time. Thus, the original special proc- 20 
ess now returns to access data from the data memory 
18. This sequence shown from zero millisecond to 
twenty millisecond is a standard mode of operation for 
processes that do not utilize the user controlled time 
slice feature as seen in the known system illustrated 25 
in Fig, 1. Again, the proc_tick_cnt value remains at 
zero, and the nojime^slice flag has not been set. 

As the special process continues to access data, 
at the twenty-five millisecond period of Fig. 5. the ac- 
cessing process arrives at data that is shared with 30 
one or more other processes. At this point the access- 
ing process has reached the beginning of a critical 
section and thus upon recognizing the possibility of 
accessing shared data, the process in step 72. Fig. 4. 
calls the e_set_no_time_slice routine 30 in the oper- 3$ 
ating system to set in step 34 the nojime_siice flag 
in the first data element of the process. No time slice 
occurs due to this action, and the proc_tick_cn lvalue 
remains at zero, while the special process continues 
to access data m step 74. Fig. 4. 40 

When the special process is accessing data in 
the critical section, the process in time comes to a 
safe point in the data. Upon coming to a safe point, a 
point where the special process has completed an 
event or series of events to fully update the accessed 45 
data, the process will call the ESCHED.CHECK util- 
ity routine 60 which is a nriodif ication of the operating 
system 21 . This is seen in the table 70 of Fig. 5 at the 
twenty-seven millisecond time. Since the process 
knows it is at a safe point in the access of the data. so 
the ESCHED_CHECK routine 60 is called. The 
ESCHEO.CHECK routine 60 checks the 
proc_tick_cnt value to see if the operating system has 
requested a tim slice 62, for if th operating system 
has requested time slic by inaementing th 55 
proc_tick_cnt in step 46. th accessing special proc- 
ess will voluntarily *give itself up' in step 66 and allow 
the operating system to initiate a time slice. At th 
twenty-seven millisecond time n th table 70, no 



user controlled time siice will occur cue co :re ooer- 
ating system not requesting a time slice, as tnctcateo 
by the proc_t!Ck_cnt value being zero. Therefore, tre 
user or special process will return in step 68 ana tnus 
continue to access data in step 76. F;g, 4. frc.n tne 
data memory 18. The nojime_slice flag wril remam 
set. 

At the thirty millisecond time of Fig. 5. another 
ten millisecond periodic interrupt signal 40 is gener- 
ated to determine if a time slice is to occur. Smce tne 
no_time_slice flag is set. no automatic :ime siice oc- 
curs, but the procjick^cnt value is incremented m 
step 46 to a value of one. This is done to indicate to 
the accessing special process that a time slice inter- 
val has elapsed. This is an advantageous feature over 
the known time slicing methods in that it avoids an au- 
tomatic time slice at the thirty millisecond time which 
would have occurred to cause a subsequent process 
to be delayed due to the data being locked. 

Upon reaching the thirty-five millisecond time of 
Fig. 5. the accessing process once again has reached 
a safe point in the data and thus once again calls the 
ESCHED_CHECK routine 60 to see if a voluntary time 
slice is appropriate. At this time the proc_tick_cnt is at 
a nonzero value. Since the time slice flag has been set 
to request a time siice. a call to ESCHED^CHECK does 
result in a time slice in step 66. The successive spe- 
cial process are then enabled to access the data with- 
out any type of delay or without any inaccuracies in 
the accessed data. Since a time slice has occurred, 
the proc Jick_cnt value is reset to a zero value in step 
64. 

At the forty millisecond time slice another period- 
ic interrupt signal is generated and results in step 46 
in incrementing the procjick^cnt value to a count of 
one since the no_time_slice flag is set. Again, be- 
cause the nojime_slice flag is set. no automatic time 
slice occurs. 

Finally, at the forty-five millisecond time of Fig. 
5. the special process with access comes to the end 
of its critical section and in step 78 calls the 
e_set_no Jime_slice routine to reset the nojime_sli- 
ce flag in step 36. Upon resetting the flag, the special 
process in step 37 will also call the ESCHED^CHECK 
routine 60 to see if the process should voluntarily 
-give itself up" and allow for a time slice to occur. At 
the forty-five millisecond point in the chart, in step 66 
a voluntary or user controlled time slice will result, 
since the proc_Uck_cnt value is at a value which is not 
equal to zero. The no_time_slice flag value wilt be re- 
turned in step 38 to the prior value it had before the 
flag was set, whicti in this case is the "ofr, or reset, 
state. 

The method for controlling access of a plurality of 
special process t a shared data menrnsry in a tele- 
phonic switching system is done through the steps of 
normally, periodically shifting access to an alterable 
data memory between th plurality of special proc- 
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esses except when orevented: determining when one 
of said plurality of special processes has access to 
snared data m said alterable data memory and pre- 
venting perooic shifting of access away from the one 5 
of said plurality of soecial processes with access dur- 
ing a oeriod when it is determined that shared data is 
being accessed by the one special process with ac- 
cess. This is aone by generating in step ^0 a periodic 
interrupt signal from the operating system 21 to re- io 
quest a time slice. The periodic shifting of access to 
the data from an accessing special process with ac- 
cess to another successive process is also controlled 
when the special process with access is enabled to 
access shared data. is 

As seen in Figs. 3A and 4. the controiling of the 
periodic shifting of access to the data is done in step 
72 by the accessing special process calling the 
e_set_no_time_sltce routine 30. Fig. 3A. which is a 
modification of the operating system, to set a flag in 20 
the no_time_slice bit of the accessing special proc- 
ess in step 34. This e_set_no_time_slice routine is 
asked to set a no_time_slice flag in step 32 in re- 
sponse to the process with access reaching a attical 
section of data which has the possibility of being data 25 
shared with other processes requesting access to the 
data. In step 78, Fig. 4. at the end of the critical sec- 
tion. e_set_nojime_stice routine 30 is called to reset 
the flag, since the special process with access is no 
longer accessing shared data. After the no_time_sli- 30 
ce flag has been reset in step 36, Fig, 3A, the state 
of the flag value will be returned in step 38 to the 
same value which the flag had prior to the flag being 
set. 

In Fig. 3C. it is seen that during the interim period 35 
from when the nojime_slice flag was set until the 
flag was turned off. or reset the controlling of the 
shifting of access to the data includes the step 46 of 
incrementing the counted tick value or proc_tick_cnt 
in a second data element of the special process ac- 40 
cessing data. This proc_tick_cnt is incremented upon 
each triggering of the periodic shifting of access to 
data or each time sikre requested in step 40 by the op- 
erating system 21 when the flag is set The step 46 
of incrementing this value is used to determine if the 45 
process has been running too long without allowing 
for a time slice. Thus, when the proc_tick_cnt reaches 
a preselected value, such as twenty, in step 48 the 
running of the special process wilt be aborted in step 
50. so that any error can be corrected. Additionally. so 
if the proc_tick_cnt value has reached a preselected 
value, such as three ticks, the a warning message is 
generated to show that a potential error may be oc- 
curring. 

The preventing of an automatic time slic upon a 55 
periodic interrupt signal from the op rating system 21 
is done by modifying th operating system with th 
e_set_n jime_slice routine 30 such that the periodic 
shifting of access to the data memory 18 wilt b 



prevented when the no_time_slice Mag is set m :re 
no_nme_slice data element oit of the accessing soe- 
ciai process, as illustrated in Fig. 3C. In Fig. a, :re 
method of having a special process access. ng cata 
from the data memory 18 is shown to include sieo rs 
calling the E3CH£D_CH£CK utility routine 60. ^hicr. 
IS a code modification of the operating system. As 
seen in Fig. 38. when the ESCHED_CH£CK rcu;ine 
60 is called, tt reads in step 62 the proc_tick_:r: 
whenever the process reaches a safe point cunng \is 
access of data from the data memory 18. If :ne 
proc_tick_cnt is a nonzero value, then the steos 64 
and 66 of resetting the proc_tick_cnt to zero and vol- 
untarily shifting access to the data memory to the 
next successive special process waiting to access 
data automatically will be taken. The step of prevent- 
ing a shifting of access to another process wilt be tak- 
en if ESCHEO_CHECK routine 60 reads a zero value 
in step 62. In such event no time slice wilt occur, and 
the special process in step 76 wilt continue to access 
shared data. 

When the critical section of data which the spe- 
cial process with access comes to an end, the step 
36 of resetting the no Jime_slice flag is taken and the 
ESCHED_CHECK utility routine 60 is called by the 
special process to see if a user controlled time slice 
is to be made. If the ESCHED_CHECK routine 60 
reads a nonzero value for the proc_tick_cnt. then m 
step 66 a voluntary shifting of access to the data 
memory 18 will be given from the special process 
with access to another successive special process 
which is waiting to access the data. 

While a detailed description of the preferred em- 
bodimentof the invention has been given, it should be 
appreciated that many variations can be made there- 
to without departing from the scope of the invention 
as set forth in the appended claims. 



Claims 

1. tn a telephonic switching system having a switch 
controlled by a central processing unit to intercon- 
nect interior communication units with exterior 
communication units, said central processing unit 
controls the switch in accordance with communi- 
cation data in a communication data memory 
which is alterable in response to signals initiated 
by said communication units in accordance with 
an operating system having a plurality of special 
processes which share the data, the improve- 
ment being a shared data memory access sys- 
tem, comprising: 

m ans for periodically shifting access to 
shared data in the data m mory successively be- 
tween said plurality of special processes: and 

means for controlling the access shifting 
means to prev nt said access shifting means 
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from shifting access to the data memory from one 
of said ptoraiity of special processes to another 
one of said plurality of special processes during 
a oenod wnen the one of said plurality of special 5 
orocesses with access lo the data memory is en- 
ablea to access shared data. 

2. The telephonic switching system of claim 1 in 
whicn said access shifting means includes io 

means associated with the operating sys- 
tem for generating a periodic interrupt signal; and 

means responsive to the interrupt signal 
to shift access to the data memory from one to 
anotherof a succession of the special processes. is 

3. The telephonic switching system of claim 1 in 
which 

the special process with access has a 
data element and 20 

said means for controlling the access 
shifting means includes means associated with 
the operating system to set a flag in the data ele- 
ment of the special process with access which is 
enabled to access shared data. 25 

4. The telephonic switching system of claim 3 in 
which said means for controlling the access shift- 
ing means includes means associated with the 
operating system to reset said flag in response to 30 
the special process accessing data from the data 
memory which is not shared data. 

5. The telephonic switching system of claim 4 in 
which the access shifting controlling means in- 3S 
dudes means for returning the state of a flag val- 
ue after the flag is reset to a same value which 

the flag had prior to the flag being set 

6. The telephonic switching system of claim 3 in 40 
which said special process with access has an* 
other data element, and the access shifting con- 
trolling means includes means for generating a 
counted tick value in another data element of the 
special process accessing data in response to 45 
the periodic access shifting means when said 

flag is set in the data element of the accessing 
special process with access. 

7. The telephonic switching system of claim 6 in 50 
which said operating system includes means re- 
sponsive to the counted tick value to stop the 
special process accessing data from c ntinuing 

to access data in respons toth counted tick val- 
ue reaching a pr selected value. 55 

8. The telephonic switching system of daim 6 in 
which said operating system includes means re- 
sponsive toth counted tick valu reaching a pre- 



selected counted tick value to signal 3 -var-^ rg 
message. 

9. The telephonic switching system of a.i.m 5 ^r. 
which said access shifting contrciling means n- 
cludes means responsive to the flag for prevent- 
ing the periodic shifting of access to ihe oata 
memory from the special process with access co 
another special process in response to the ^iag 
being set in the data element of the special crcc- 
ess with access. 

10. The telephonic switching system of claim 6 m 
which said means for controlling the access snif t- 
ing means includes 

means associated with the special proc- 
ess with access in to determine when reaching a 
safe point has been reached during the access- 
ing of data, and 

means associated with the operating sys- 
tem and responsive to the special process with 
access to read the counted tick value in the other 
data element of the special process with access. 

11. The telephonic switching system of claim 10 in 
which said means associated with the operating 
system to read the counted tick value includes 

means for resetting the counted tick value 
to zero and 

means for automatically shifting access to 
the data memory from the special process with 
access to another special process in response to 
an initial reading of the counted tick value being 
nonzero. 

12. The telephonic switching system of claim 10 in 
which said means associated with the operating 
system to read the counted tick value includes 
means for preventing a shifting of access to the 
data memory from the special process with ac- 
cess to another special process in response to a 
reading of the counted tick value being zero. 

13. The telephonic switching system of claim 10 in 
which said means for controlling the access shift- 
ing means includes 

means associated with the operating sys- 
tem to reset said flag in response to the special 
process with access accessing nonshared data: 
and 

means associated with the operating sys- 
tem to read said counted tick value in response to 
said means associated with the operating system 
to reset sakj flag and m ans to automatically pro- 
vide a shifting of access to the data memory from 
th special process with access to another spe- 
cial process in respons to said tick value reading 
means reading a nonzero tick value. 
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14. In a telephonic switching system having a switch 
controlleo by a central processing unit to intercept 
comnnunication units m accordance with entry in 
a data memory including shared data which is at- 
teraoie m resDonse to signals initiated by said 
communication m accordance with an operation 
system navmg a plurality of special processes 
wnich share at least some of the data, the im- 
provement being a method of controlling access 
of the special processes to the shared data com- 
prising the steps of: 

normally periodically shifting access to 
the alterable data memory between said plurality 
of special processes except when prevented; 

determining when one of said plurality of 
special processes has access to shared data in 
said alterable data memory; and 

preventing periodic shifting of access 
away from the one of said plurality of special 
processes with access during a period when it is 
determined that shared data is being accessed 
by the one special process with access. 

15. The shared data access controtiing method of 
claim 14 in which the step of periodically shifting 
access to the data memory includes the steps of 

generating a periodic interrupt signal by 
means associated with the operating system, 
and 

normally shifting access to the data mem- 
ory from one to the next of the plurality of special 
processes in response to the penodic interrupt 

signal. 

16. The snared data access controlling method of 
claim 14 in which the special process with access 
has a oata element and the step of controlling the 
penodic shifting of access includes the step of 

setting a flag in the data element of the 
special process which is accessing the data. 

17. The shared data access controlling method of 
claim 16 in which the step of controlling the per- 
iodic shifting of access includes the step of 

resening the flag in response to the spe- 
cial process accessing data from the data mem- 
ory which is nonshared data. 

18. The shared data access controlling method of ac- 
cessing data of daim 1 7 in which the step of con- 
trolling the periodic shifting of access includes 
the step of 

returning the state of a flag valu after the 
flag is res t to a same value which the flag had 
prior to the flag b ing s t 

19. The shared data access controlling meth d of 
claim 1 6 in which the special process has an ther 



data element and the steo of controiiing :re zer- 
iodic shifting of access includes the steo of 

incrementing a counted tick value 'O a-- 
5 other data element of the special orocess ^itn 

access from said data memory in resoonse :o 
each periodic shifting of access to the data mem- 
ory when the flag is set m the oata element of tre 
special process with access. 

TO 

20. The shared data access controlling metnoa of 
claim 19 in which the step of controlling the per- 
iodic shifting of access includes the steo of 

aborting the running of the soeciai rrcc- 
15 ess accessing data in response to :rie cot r :9c 

tick value reaching a preselected value. 

21. The shared data access controlling method of 
claim 19 in which the step of controlling the per- 

20 iodic shifting of access includes the step of 

signalling a warning message in response 
to the counted tick value reaching a preselected 
value. 

25 22. The shared data access controlling method of 
claim 19 in which the step of controlling the per- 
iodic shifting of access includes the step of 

preventing the periodic shifting of access 
to the data memory from the accessing special 

30 process to another successive special process in 

response to the flag being set in the data element 
of the accessing special process. 

23. The shared data access controlling method of 
35 claim 19 in which the step of controlling the per- 
iodic shifting of access includes the step of 

causing the counted tick value in the other 
data element of the accessing special process to 
be read in response to the special process with 
40 access reaching a safe point during the access of 

data from the data memory. 

24. The shared data access controlling method of 
claim 23 including the steps of 

4$ resetting the counted tick value to zero. 

reading the counted tick value, and 
automabcally shifting access to the data 
memory from the special process with access to 
another successive special process when the 
50 counted tick value is read as being a value other 

than zero. 

25. The shared data access controlling method of 
claim 23 including the steps of 

55 reading the counted tick value, and 

preventing a shifting of access to the data 
memory from the special process with access to 
another successive special process in response 
to the read tick value being zero. 
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26. The shared data access controlling method of 
claim 23 in which the step of controlling the per- 
iodic shifting of access includes the steps of 

resecting the flag in response to the ac- 5 
cessrng special process accessing nonshared 
data, and 

causing the counted tick value to be read 
in response to the resetting of the flag, and 

autonnatically shifting access from the io 
special process with access to another succes- 
sive special process in response to reading a 
nonzero counted tick value. 

J5 
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